package com.xupt.easy.stack;

import java.util.Stack;

/**
 * @author zhaoxin
 * @title: CalPoints
 * @projectName LeetCode
 * @description: 682. 棒球比赛
 * @date 2020/1/2 17:36
 */
public class CalPoints {


    /**
     * 你现在是棒球比赛记录员。
     * 给定一个字符串列表，每个字符串可以是以下四种类型之一：
     * 1.整数（一轮的得分）：直接表示您在本轮中获得的积分数。
     * 2. "+"（一轮的得分）：表示本轮获得的得分是前两轮有效 回合得分的总和。
     * 3. "D"（一轮的得分）：表示本轮获得的得分是前一轮有效 回合得分的两倍。
     * 4. "C"（一个操作，这不是一个回合的分数）：表示您获得的最后一个有效 回合的分数是无效的，应该被移除。
     *
     * 每一轮的操作都是永久性的，可能会对前一轮和后一轮产生影响。
     * 你需要返回你在所有回合中得分的总和。
     *
     * 示例 1:
     *
     * 输入: ["5","2","C","D","+"]
     * 输出: 30
     * 解释:
     * 第1轮：你可以得到5分。总和是：5。
     * 第2轮：你可以得到2分。总和是：7。
     * 操作1：第2轮的数据无效。总和是：5。
     * 第3轮：你可以得到10分（第2轮的数据已被删除）。总数是：15。
     * 第4轮：你可以得到5 + 10 = 15分。总数是：30。
     *
     * @param ops
     * @return
     */
    public int calPoints(String[] ops) {
        // 存有效的分数
        Stack<Integer> stack = new Stack<>();
        for (String s : ops) {
            if ("+".equals(s)){
                Integer popScore = stack.pop();
                Integer lastScore = stack.peek();
                stack.push(popScore);
                stack.push(popScore + lastScore);
            }else if ("D".equals(s)){
                stack.push(2 * stack.peek());
            }else if ("C".equals(s)){
                stack.pop();
            }else {
                stack.push(Integer.valueOf(s));
            }
        }
        // 计算分数
        int sum = 0;
        for (Integer score : stack) {
            sum = sum + score;
        }

        return sum;
    }
}
